草庐IT

Python 正则表达式 findall

全部标签

ruby - 有效的电子邮件地址正则表达式?

这个问题在这里已经有了答案:HowcanIvalidateanemailaddressusingaregularexpression?(80个答案)关闭9年前。我已经做了一些测试,但我想问问是否有人发现这个用于电子邮件验证的ruby​​正则表达式有问题:/\A([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})\Z/i好看吗?

使用正则表达式的 Ruby 电子邮件验证

我有一大堆正在浏览的电子邮件。很多邮件都有拼写错误。我正在尝试构建一个字符串来检查有效的电子邮件。这就是我的正则表达式。defis_a_valid_email?(email)(email=~/^(([A-Za-z0-9]*\.+*_+)|([A-Za-z0-9]+\-+)|([A-Za-z0-9]+\+)|([A-Za-z0-9]+\+))*[A-Z‌​a-z0-9]+@{1}((\w+\-+)|(\w+\.))*\w{1,63}\.[a-zA-Z]{2,4}$/i)end如果电子邮件为下划线且只有一个句点,则通过。我有很多电子邮件的名称本身有不止一个句点。我如何在正则表达式中检查它。

ruby - 从 Ruby 中的字符串创建不区分大小写的正则表达式

假设我有一个任意的字符串`Aman+aplan*acanal:Panama!`我想对大小写不同的字符串进行正则表达式搜索。也就是说,这个正则表达式应该匹配字符串`aman+APLAN*acanal:PaNaMa!`我认为最好的方法是在Ruby正则表达式中对每个具有特殊含义的字符进行反斜杠转义,然后使用该字符串执行Regexp.new和Regexp::IGNORECASE作为参数。是对的吗?是否存在用于将任意字符串转换为文字正则表达式的经过验证的正则表达式?顺便说一下,我最终想使用这个正则表达式来做一个任意的不区分大小写的MongoDB查询。因此,如果我有其他方法可以做到这一点,请告诉我

ruby - 如何在 ruby​​ 中针对正则表达式测试整个字符串?

如果整个字符串匹配(而不是子字符串),我如何针对正则表达式设置字符串以返回true?例如:test(\ee\,"street")#=>returnsfalsetest(\ee\,"ee")#=>returnstrue!谢谢。 最佳答案 您可以用\A匹配字符串的开头,用\Z匹配结尾。在ruby​​中,^和$也分别匹配行的开头和结尾:>>"a\na"=~/^a$/=>0>>"a\na"=~/\Aa\Z/=>nil>>"a\na"=~/\Aa\na\Z/=>0 关于ruby-如何在ruby​​

Ruby 全局匹配正则表达式?

在其他语言中,在RegExp中,您可以使用/.../g进行全局匹配。然而,在Ruby中:"hellohello".match/(hello)/只捕获一个问候语。如何捕获所有的hello? 最佳答案 您可以使用扫描方法。scan方法将为您提供所有匹配项的数组,或者如果您将其传递给一个block,则将每个匹配项传递给该block。"hello1hello2".scan(/(hello\d+)/)#=>[["hello1"],["hello2"]]"hello1hello2".scan(/(hello\d+)/).eachdo|m|put

ruby - 正则表达式中的 `?i` 和 `?-i` 是什么意思?

谁能解释一下(?i)和(?-i)在正则表达式中包裹一个词是什么意思?(?i)test(?-i)我测试过,它匹配test、TEST和teSt。但我以前从未见过这个。i之前的?是什么意思?我看到这个here. 最佳答案 (?i)开始不区分大小写模式(?-i)关闭不区分大小写模式更多信息请访问"TurningModesOnandOffforOnlyPartofTheRegularExpression"sectionofthispage:Modernregexflavorsallowyoutoapplymodifierstoonlypart

ruby - 正则表达式,如何匹配多行?

我正在尝试将From行一直匹配到Subject行的末尾,如下所示:....From:XXXXXXDate:Tue,8Mar201110:52:42-0800To:XXXXXXXSubject:XXXXXXX....到目前为止我有:/From:.*Date:.*To:.*Subject/m但这与主题行的末尾不匹配。我尝试添加$但没有效果。 最佳答案 您可以使用/m修饰符启用多行模式(即允许.匹配换行符),您可以使用?执行非贪婪匹配:message="From:person@example.com\nDate:01-01-2011\nT

ruby - 将 Ruby 正则表达式拆分为多行

这可能不是您所期待的问题!我不想要一个匹配换行符的正则表达式;相反,我想写一个很长的正则表达式,为了可读性,我想分成多行代码。类似于:"bar"=~/(foo|bar)/#Doesn'twork!#=>nil.Wouldlike=>0可以吗? 最佳答案 将%r与x选项一起使用是执行此操作的首选方法。请参阅githubruby​​样式指南中的示例regexp=%r{start#sometext\s#whitespacechar(group)#firstgroup(?:alt1|alt2)#somealternationend}xreg

ruby - 为什么表达式 (true == true == true) 会产生语法错误?

ruby:true==true==truesyntaxerror,unexpectedtEQ对比JavaScript:true==true==true//=>true对比C:1==1==1//=>1 最佳答案 关联方向控制运算符对其参数求值的顺序,未为==定义。方法,与===相同,!=,=~和方法也是如此(所有方法都具有相同的优先级,并且专门形成一个单独的优先级组)。Documentation因此,如果上述列表中的多个运算符被链接成一行,则应通过任一方式显式设置评估顺序括号():(true==true)==true#=>truetr

ruby - 检查字符串是否与 ruby​​ 中的正则表达式匹配的最快方法?

检查字符串是否与Ruby中的正则表达式匹配的最快方法是什么?我的问题是我必须“egrep”一个巨大的字符串列表以找到哪些匹配运行时给定的正则表达式。我只关心字符串是否匹配正则表达式,不关心匹配到哪里,也不关心匹配组的内容是什么。我希望这个假设可以用来减少我的代码花在匹配上的时间正则表达式。我加载正则表达式pattern=Regexp.new(ptx).freeze我发现string=~pattern比string.match(pattern)稍快。是否有其他技巧或快捷方式可用于使此测试更快? 最佳答案 从Ruby2.4.0开始,您可